<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <script src="./vue.js"></script>
  </head>
  <body>
    <div id="app">
      <!-- 给组件模板找个位置渲染 -->
      <my-list>123</my-list>
    </div>
  </body>
  <script>
    // 容器组件
    //
    let app = Vue.createApp({
      data() {
        return {};
      },
    });
    // 组件也是vue实例  对比函数 理解组件
    // 注册组件 组件名 组件选项  可以在当前根实例下的所有vue实例模板中使用
    app.component("my-list", {
      // 类似函数的局部变量
      // 自己的东西自己用
      data() {
        return {};
      },
      // 组件模板  相当于函数的返回值
      // <slot></slot> 调用组件时的标签内容
      template: `
        <h1>组件</h1>
        <slot></slot>
      `,
    });
    app = app.mount("#app");
  </script>
</html>
